package it.unipd.dei.bd.icineasti.database;

import it.unipd.dei.bd.icineasti.resource.Tecnico;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 * Restituisce i dati di un tecnico dato il suo codice fiscale.
 * 
 * @author Visentin Lorenzo
 * @version 1.00
 */
public class GetDatiTecnicoFromCodFiscDatabase {

	/**
	 * Interrogazione al database.
	 */
	private static final String STATEMENT = "SELECT * FROM Tecnico " +
											"WHERE CodFiscale = ?";
	
	/**
	 * Connessione al database
	 */
	private final Connection con;
	
	/**
	 * Codice fiscale del tecnico
	 */
	private final String codFiscale;
	
	/**
	 * Risultati della ricerca
	 */
	private Tecnico tecnico;
	
	/**
	 * Passo il c.f. del tecnico e ricavo i suoi dati.
	 */
	public GetDatiTecnicoFromCodFiscDatabase(Connection con, String codFiscale) {
		this.con = con;
		this.codFiscale = codFiscale;
		tecnico = null;
	}

	public Tecnico getTecnico() throws SQLException {

		PreparedStatement pstmt = null;
		ResultSet rs = null;

		try {
			pstmt = con.prepareStatement(STATEMENT);
			pstmt.setString(1, codFiscale);

			rs = pstmt.executeQuery();
			if (rs.next()) {
				tecnico = new Tecnico(
										rs.getInt("CodiceSede"),
										rs.getString("CodFiscale"),
										rs.getString("Cognome"),
										rs.getString("Nome")
									);
			}

		} finally {
			if (rs != null) {
				rs.close();
			}

			if (pstmt != null) {
				pstmt.close();
			}

			con.close();
		}

		return tecnico;
	}
}
